home *** CD-ROM | disk | FTP | other *** search
/ Mac Easy 2010 May / Mac Life Ubuntu.iso / casper / filesystem.squashfs / usr / src / linux-headers-2.6.28-15 / arch / arm / plat-mxc / include / mach / iomux-mx1-mx2.h < prev    next >
Encoding:
C/C++ Source or Header  |  2008-12-24  |  20.3 KB  |  397 lines

  1. /*
  2.  * Copyright (C) 2008 by Sascha Hauer <kernel@pengutronix.de>
  3.  *
  4.  * This program is free software; you can redistribute it and/or
  5.  * modify it under the terms of the GNU General Public License
  6.  * as published by the Free Software Foundation; either version 2
  7.  * of the License, or (at your option) any later version.
  8.  * This program is distributed in the hope that it will be useful,
  9.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.  * GNU General Public License for more details.
  12.  *
  13.  * You should have received a copy of the GNU General Public License
  14.  * along with this program; if not, write to the Free Software
  15.  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
  16.  * MA 02110-1301, USA.
  17.  */
  18.  
  19. #ifndef _MXC_GPIO_MX1_MX2_H
  20. #define _MXC_GPIO_MX1_MX2_H
  21.  
  22. #include <linux/io.h>
  23.  
  24. #define MXC_GPIO_ALLOC_MODE_NORMAL    0
  25. #define MXC_GPIO_ALLOC_MODE_NO_ALLOC    1
  26. #define MXC_GPIO_ALLOC_MODE_TRY_ALLOC    2
  27. #define MXC_GPIO_ALLOC_MODE_ALLOC_ONLY    4
  28. #define MXC_GPIO_ALLOC_MODE_RELEASE    8
  29.  
  30. /*
  31.  *  GPIO Module and I/O Multiplexer
  32.  *  x = 0..3 for reg_A, reg_B, reg_C, reg_D
  33.  */
  34. #define VA_GPIO_BASE    IO_ADDRESS(GPIO_BASE_ADDR)
  35. #define MXC_DDIR(x)    (0x00 + ((x) << 8))
  36. #define MXC_OCR1(x)    (0x04 + ((x) << 8))
  37. #define MXC_OCR2(x)    (0x08 + ((x) << 8))
  38. #define MXC_ICONFA1(x) (0x0c + ((x) << 8))
  39. #define MXC_ICONFA2(x) (0x10 + ((x) << 8))
  40. #define MXC_ICONFB1(x) (0x14 + ((x) << 8))
  41. #define MXC_ICONFB2(x) (0x18 + ((x) << 8))
  42. #define MXC_DR(x)      (0x1c + ((x) << 8))
  43. #define MXC_GIUS(x)    (0x20 + ((x) << 8))
  44. #define MXC_SSR(x)     (0x24 + ((x) << 8))
  45. #define MXC_ICR1(x)    (0x28 + ((x) << 8))
  46. #define MXC_ICR2(x)    (0x2c + ((x) << 8))
  47. #define MXC_IMR(x)     (0x30 + ((x) << 8))
  48. #define MXC_ISR(x)     (0x34 + ((x) << 8))
  49. #define MXC_GPR(x)     (0x38 + ((x) << 8))
  50. #define MXC_SWR(x)     (0x3c + ((x) << 8))
  51. #define MXC_PUEN(x)    (0x40 + ((x) << 8))
  52.  
  53. #ifdef CONFIG_ARCH_MX1
  54. # define GPIO_PORT_MAX  3
  55. #endif
  56. #ifdef CONFIG_ARCH_MX2
  57. # define GPIO_PORT_MAX  5
  58. #endif
  59.  
  60. #ifndef GPIO_PORT_MAX
  61. # error "GPIO config port count unknown!"
  62. #endif
  63.  
  64. #define GPIO_PIN_MASK 0x1f
  65.  
  66. #define GPIO_PORT_SHIFT 5
  67. #define GPIO_PORT_MASK (0x7 << GPIO_PORT_SHIFT)
  68.  
  69. #define GPIO_PORTA (0 << GPIO_PORT_SHIFT)
  70. #define GPIO_PORTB (1 << GPIO_PORT_SHIFT)
  71. #define GPIO_PORTC (2 << GPIO_PORT_SHIFT)
  72. #define GPIO_PORTD (3 << GPIO_PORT_SHIFT)
  73. #define GPIO_PORTE (4 << GPIO_PORT_SHIFT)
  74. #define GPIO_PORTF (5 << GPIO_PORT_SHIFT)
  75.  
  76. #define GPIO_OUT   (1 << 8)
  77. #define GPIO_IN    (0 << 8)
  78. #define GPIO_PUEN  (1 << 9)
  79.  
  80. #define GPIO_PF    (1 << 10)
  81. #define GPIO_AF    (1 << 11)
  82.  
  83. #define GPIO_OCR_SHIFT 12
  84. #define GPIO_OCR_MASK (3 << GPIO_OCR_SHIFT)
  85. #define GPIO_AIN   (0 << GPIO_OCR_SHIFT)
  86. #define GPIO_BIN   (1 << GPIO_OCR_SHIFT)
  87. #define GPIO_CIN   (2 << GPIO_OCR_SHIFT)
  88. #define GPIO_GPIO  (3 << GPIO_OCR_SHIFT)
  89.  
  90. #define GPIO_AOUT_SHIFT 14
  91. #define GPIO_AOUT_MASK (3 << GPIO_AOUT_SHIFT)
  92. #define GPIO_AOUT     (0 << GPIO_AOUT_SHIFT)
  93. #define GPIO_AOUT_ISR (1 << GPIO_AOUT_SHIFT)
  94. #define GPIO_AOUT_0   (2 << GPIO_AOUT_SHIFT)
  95. #define GPIO_AOUT_1   (3 << GPIO_AOUT_SHIFT)
  96.  
  97. #define GPIO_BOUT_SHIFT 16
  98. #define GPIO_BOUT_MASK (3 << GPIO_BOUT_SHIFT)
  99. #define GPIO_BOUT      (0 << GPIO_BOUT_SHIFT)
  100. #define GPIO_BOUT_ISR  (1 << GPIO_BOUT_SHIFT)
  101. #define GPIO_BOUT_0    (2 << GPIO_BOUT_SHIFT)
  102. #define GPIO_BOUT_1    (3 << GPIO_BOUT_SHIFT)
  103.  
  104. extern void mxc_gpio_mode(int gpio_mode);
  105. extern int mxc_gpio_setup_multiple_pins(const int *pin_list, unsigned count,
  106.                     int alloc_mode, const char *label);
  107.  
  108. /*-------------------------------------------------------------------------*/
  109.  
  110. /* assignements for GPIO alternate/primary functions */
  111.  
  112. /* FIXME: This list is not completed. The correct directions are
  113.  * missing on some (many) pins
  114.  */
  115. #ifdef CONFIG_ARCH_MX1
  116. #define PA0_AIN_SPI2_CLK     (GPIO_GIUS | GPIO_PORTA | GPIO_OUT | 0)
  117. #define PA0_AF_ETMTRACESYNC  (GPIO_PORTA | GPIO_AF | 0)
  118. #define PA1_AOUT_SPI2_RXD    (GPIO_GIUS | GPIO_PORTA | GPIO_IN | 1)
  119. #define PA1_PF_TIN           (GPIO_PORTA | GPIO_PF | 1)
  120. #define PA2_PF_PWM0          (GPIO_PORTA | GPIO_OUT | GPIO_PF | 2)
  121. #define PA3_PF_CSI_MCLK      (GPIO_PORTA | GPIO_PF | 3)
  122. #define PA4_PF_CSI_D0        (GPIO_PORTA | GPIO_PF | 4)
  123. #define PA5_PF_CSI_D1        (GPIO_PORTA | GPIO_PF | 5)
  124. #define PA6_PF_CSI_D2        (GPIO_PORTA | GPIO_PF | 6)
  125. #define PA7_PF_CSI_D3        (GPIO_PORTA | GPIO_PF | 7)
  126. #define PA8_PF_CSI_D4        (GPIO_PORTA | GPIO_PF | 8)
  127. #define PA9_PF_CSI_D5        (GPIO_PORTA | GPIO_PF | 9)
  128. #define PA10_PF_CSI_D6       (GPIO_PORTA | GPIO_PF | 10)
  129. #define PA11_PF_CSI_D7       (GPIO_PORTA | GPIO_PF | 11)
  130. #define PA12_PF_CSI_VSYNC    (GPIO_PORTA | GPIO_PF | 12)
  131. #define PA13_PF_CSI_HSYNC    (GPIO_PORTA | GPIO_PF | 13)
  132. #define PA14_PF_CSI_PIXCLK   (GPIO_PORTA | GPIO_PF | 14)
  133. #define PA15_PF_I2C_SDA      (GPIO_PORTA | GPIO_OUT | GPIO_PF | 15)
  134. #define PA16_PF_I2C_SCL      (GPIO_PORTA | GPIO_OUT | GPIO_PF | 16)
  135. #define PA17_AF_ETMTRACEPKT4 (GPIO_PORTA | GPIO_AF | 17)
  136. #define PA17_AIN_SPI2_SS     (GPIO_GIUS | GPIO_PORTA | GPIO_OUT | 17)
  137. #define PA18_AF_ETMTRACEPKT5 (GPIO_PORTA | GPIO_AF | 18)
  138. #define PA19_AF_ETMTRACEPKT6 (GPIO_PORTA | GPIO_AF | 19)
  139. #define PA20_AF_ETMTRACEPKT7 (GPIO_PORTA | GPIO_AF | 20)
  140. #define PA21_PF_A0           (GPIO_PORTA | GPIO_PF | 21)
  141. #define PA22_PF_CS4          (GPIO_PORTA | GPIO_PF | 22)
  142. #define PA23_PF_CS5          (GPIO_PORTA | GPIO_PF | 23)
  143. #define PA24_PF_A16          (GPIO_PORTA | GPIO_PF | 24)
  144. #define PA24_AF_ETMTRACEPKT0 (GPIO_PORTA | GPIO_AF | 24)
  145. #define PA25_PF_A17          (GPIO_PORTA | GPIO_PF | 25)
  146. #define PA25_AF_ETMTRACEPKT1 (GPIO_PORTA | GPIO_AF | 25)
  147. #define PA26_PF_A18          (GPIO_PORTA | GPIO_PF | 26)
  148. #define PA26_AF_ETMTRACEPKT2 (GPIO_PORTA | GPIO_AF | 26)
  149. #define PA27_PF_A19          (GPIO_PORTA | GPIO_PF | 27)
  150. #define PA27_AF_ETMTRACEPKT3 (GPIO_PORTA | GPIO_AF | 27)
  151. #define PA28_PF_A20          (GPIO_PORTA | GPIO_PF | 28)
  152. #define PA28_AF_ETMPIPESTAT0 (GPIO_PORTA | GPIO_AF | 28)
  153. #define PA29_PF_A21          (GPIO_PORTA | GPIO_PF | 29)
  154. #define PA29_AF_ETMPIPESTAT1 (GPIO_PORTA | GPIO_AF | 29)
  155. #define PA30_PF_A22          (GPIO_PORTA | GPIO_PF | 30)
  156. #define PA30_AF_ETMPIPESTAT2 (GPIO_PORTA | GPIO_AF | 30)
  157. #define PA31_PF_A23          (GPIO_PORTA | GPIO_PF | 31)
  158. #define PA31_AF_ETMTRACECLK  (GPIO_PORTA | GPIO_AF | 31)
  159. #define PB8_PF_SD_DAT0       (GPIO_PORTB | GPIO_PF | GPIO_PUEN | 8)
  160. #define PB8_AF_MS_PIO        (GPIO_PORTB | GPIO_AF | 8)
  161. #define PB9_PF_SD_DAT1       (GPIO_PORTB | GPIO_PF | GPIO_PUEN  | 9)
  162. #define PB9_AF_MS_PI1        (GPIO_PORTB | GPIO_AF | 9)
  163. #define PB10_PF_SD_DAT2      (GPIO_PORTB | GPIO_PF | GPIO_PUEN  | 10)
  164. #define PB10_AF_MS_SCLKI     (GPIO_PORTB | GPIO_AF | 10)
  165. #define PB11_PF_SD_DAT3      (GPIO_PORTB | GPIO_PF | 11)
  166. #define PB11_AF_MS_SDIO      (GPIO_PORTB | GPIO_AF | 11)
  167. #define PB12_PF_SD_CLK       (GPIO_PORTB | GPIO_PF | 12)
  168. #define PB12_AF_MS_SCLK0     (GPIO_PORTB | GPIO_AF | 12)
  169. #define PB13_PF_SD_CMD       (GPIO_PORTB | GPIO_PF | GPIO_PUEN | 13)
  170. #define PB13_AF_MS_BS        (GPIO_PORTB | GPIO_AF | 13)
  171. #define PB14_AF_SSI_RXFS     (GPIO_PORTB | GPIO_AF | 14)
  172. #define PB15_AF_SSI_RXCLK    (GPIO_PORTB | GPIO_AF | 15)
  173. #define PB16_AF_SSI_RXDAT    (GPIO_PORTB | GPIO_IN | GPIO_AF | 16)
  174. #define PB17_AF_SSI_TXDAT    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 17)
  175. #define PB18_AF_SSI_TXFS     (GPIO_PORTB | GPIO_AF | 18)
  176. #define PB19_AF_SSI_TXCLK    (GPIO_PORTB | GPIO_AF | 19)
  177. #define PB20_PF_USBD_AFE     (GPIO_PORTB | GPIO_PF | 20)
  178. #define PB21_PF_USBD_OE      (GPIO_PORTB | GPIO_PF | 21)
  179. #define PB22_PFUSBD_RCV      (GPIO_PORTB | GPIO_PF | 22)
  180. #define PB23_PF_USBD_SUSPND  (GPIO_PORTB | GPIO_PF | 23)
  181. #define PB24_PF_USBD_VP      (GPIO_PORTB | GPIO_PF | 24)
  182. #define PB25_PF_USBD_VM      (GPIO_PORTB | GPIO_PF | 25)
  183. #define PB26_PF_USBD_VPO     (GPIO_PORTB | GPIO_PF | 26)
  184. #define PB27_PF_USBD_VMO     (GPIO_PORTB | GPIO_PF | 27)
  185. #define PB28_PF_UART2_CTS    (GPIO_PORTB | GPIO_OUT | GPIO_PF | 28)
  186. #define PB29_PF_UART2_RTS    (GPIO_PORTB | GPIO_IN | GPIO_PF | 29)
  187. #define PB30_PF_UART2_TXD    (GPIO_PORTB | GPIO_OUT | GPIO_PF | 30)
  188. #define PB31_PF_UART2_RXD    (GPIO_PORTB | GPIO_IN | GPIO_PF | 31)
  189. #define PC3_PF_SSI_RXFS      (GPIO_PORTC | GPIO_PF | 3)
  190. #define PC4_PF_SSI_RXCLK     (GPIO_PORTC | GPIO_PF | 4)
  191. #define PC5_PF_SSI_RXDAT     (GPIO_PORTC | GPIO_IN | GPIO_PF | 5)
  192. #define PC6_PF_SSI_TXDAT     (GPIO_PORTC | GPIO_OUT | GPIO_PF | 6)
  193. #define PC7_PF_SSI_TXFS      (GPIO_PORTC | GPIO_PF | 7)
  194. #define PC8_PF_SSI_TXCLK     (GPIO_PORTC | GPIO_PF | 8)
  195. #define PC9_PF_UART1_CTS     (GPIO_PORTC | GPIO_OUT | GPIO_PF | 9)
  196. #define PC10_PF_UART1_RTS    (GPIO_PORTC | GPIO_IN | GPIO_PF | 10)
  197. #define PC11_PF_UART1_TXD    (GPIO_PORTC | GPIO_OUT | GPIO_PF | 11)
  198. #define PC12_PF_UART1_RXD    (GPIO_PORTC | GPIO_IN | GPIO_PF | 12)
  199. #define PC13_PF_SPI1_SPI_RDY (GPIO_PORTC | GPIO_PF | 13)
  200. #define PC14_PF_SPI1_SCLK    (GPIO_PORTC | GPIO_PF | 14)
  201. #define PC15_PF_SPI1_SS      (GPIO_PORTC | GPIO_PF | 15)
  202. #define PC16_PF_SPI1_MISO    (GPIO_PORTC | GPIO_PF | 16)
  203. #define PC17_PF_SPI1_MOSI    (GPIO_PORTC | GPIO_PF | 17)
  204. #define PC24_BIN_UART3_RI    (GPIO_GIUS | GPIO_PORTC | GPIO_OUT | GPIO_BIN | 24)
  205. #define PC25_BIN_UART3_DSR   (GPIO_GIUS | GPIO_PORTC | GPIO_OUT | GPIO_BIN | 25)
  206. #define PC26_AOUT_UART3_DTR  (GPIO_GIUS | GPIO_PORTC | GPIO_IN | 26)
  207. #define PC27_BIN_UART3_DCD   (GPIO_GIUS | GPIO_PORTC | GPIO_OUT | GPIO_BIN | 27)
  208. #define PC28_BIN_UART3_CTS   (GPIO_GIUS | GPIO_PORTC | GPIO_OUT | GPIO_BIN | 28)
  209. #define PC29_AOUT_UART3_RTS  (GPIO_GIUS | GPIO_PORTC | GPIO_IN | 29)
  210. #define PC30_BIN_UART3_TX    (GPIO_GIUS | GPIO_PORTC | GPIO_BIN | 30)
  211. #define PC31_AOUT_UART3_RX   (GPIO_GIUS | GPIO_PORTC | GPIO_IN | 31)
  212. #define PD6_PF_LSCLK         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 6)
  213. #define PD7_PF_REV           (GPIO_PORTD | GPIO_PF | 7)
  214. #define PD7_AF_UART2_DTR     (GPIO_GIUS | GPIO_PORTD | GPIO_IN | GPIO_AF | 7)
  215. #define PD7_AIN_SPI2_SCLK    (GPIO_GIUS | GPIO_PORTD | GPIO_AIN | 7)
  216. #define PD8_PF_CLS           (GPIO_PORTD | GPIO_PF | 8)
  217. #define PD8_AF_UART2_DCD     (GPIO_PORTD | GPIO_OUT | GPIO_AF | 8)
  218. #define PD8_AIN_SPI2_SS      (GPIO_GIUS | GPIO_PORTD | GPIO_AIN | 8)
  219. #define PD9_PF_PS            (GPIO_PORTD | GPIO_PF | 9)
  220. #define PD9_AF_UART2_RI      (GPIO_PORTD | GPIO_OUT | GPIO_AF | 9)
  221. #define PD9_AOUT_SPI2_RXD    (GPIO_GIUS | GPIO_PORTD | GPIO_IN | 9)
  222. #define PD10_PF_SPL_SPR      (GPIO_PORTD | GPIO_OUT | GPIO_PF | 10)
  223. #define PD10_AF_UART2_DSR    (GPIO_PORTD | GPIO_OUT | GPIO_AF | 10)
  224. #define PD10_AIN_SPI2_TXD    (GPIO_GIUS | GPIO_PORTD | GPIO_OUT | 10)
  225. #define PD11_PF_CONTRAST     (GPIO_PORTD | GPIO_OUT | GPIO_PF | 11)
  226. #define PD12_PF_ACD_OE       (GPIO_PORTD | GPIO_OUT | GPIO_PF | 12)
  227. #define PD13_PF_LP_HSYNC     (GPIO_PORTD | GPIO_OUT | GPIO_PF | 13)
  228. #define PD14_PF_FLM_VSYNC    (GPIO_PORTD | GPIO_OUT | GPIO_PF | 14)
  229. #define PD15_PF_LD0          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 15)
  230. #define PD16_PF_LD1          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 16)
  231. #define PD17_PF_LD2          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 17)
  232. #define PD18_PF_LD3          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 18)
  233. #define PD19_PF_LD4          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 19)
  234. #define PD20_PF_LD5          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 20)
  235. #define PD21_PF_LD6          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 21)
  236. #define PD22_PF_LD7          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 22)
  237. #define PD23_PF_LD8          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 23)
  238. #define PD24_PF_LD9          (GPIO_PORTD | GPIO_OUT | GPIO_PF | 24)
  239. #define PD25_PF_LD10         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 25)
  240. #define PD26_PF_LD11         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 26)
  241. #define PD27_PF_LD12         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 27)
  242. #define PD28_PF_LD13         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 28)
  243. #define PD29_PF_LD14         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 29)
  244. #define PD30_PF_LD15         (GPIO_PORTD | GPIO_OUT | GPIO_PF | 30)
  245. #define PD31_PF_TMR2OUT      (GPIO_PORTD | GPIO_PF | 31)
  246. #define PD31_BIN_SPI2_TXD    (GPIO_GIUS | GPIO_PORTD | GPIO_BIN | 31)
  247. #endif
  248.  
  249. #ifdef CONFIG_ARCH_MX2
  250. #define PA0_PF_USBH2_CLK    (GPIO_PORTA | GPIO_PF | 0)
  251. #define PA1_PF_USBH2_DIR    (GPIO_PORTA | GPIO_PF | 1)
  252. #define PA2_PF_USBH2_DATA7    (GPIO_PORTA | GPIO_PF | 2)
  253. #define PA3_PF_USBH2_NXT    (GPIO_PORTA | GPIO_PF | 3)
  254. #define PA4_PF_USBH2_STP    (GPIO_PORTA | GPIO_PF | 4)
  255. #define PA5_PF_LSCLK        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 5)
  256. #define PA6_PF_LD0        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 6)
  257. #define PA7_PF_LD1        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 7)
  258. #define PA8_PF_LD2        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 8)
  259. #define PA9_PF_LD3        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 9)
  260. #define PA10_PF_LD4        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 10)
  261. #define PA11_PF_LD5        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 11)
  262. #define PA12_PF_LD6        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 12)
  263. #define PA13_PF_LD7        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 13)
  264. #define PA14_PF_LD8        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 14)
  265. #define PA15_PF_LD9        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 15)
  266. #define PA16_PF_LD10        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 16)
  267. #define PA17_PF_LD11        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 17)
  268. #define PA18_PF_LD12        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 18)
  269. #define PA19_PF_LD13        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 19)
  270. #define PA20_PF_LD14        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 20)
  271. #define PA21_PF_LD15        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 21)
  272. #define PA22_PF_LD16        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 22)
  273. #define PA23_PF_LD17        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 23)
  274. #define PA24_PF_REV        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 24)
  275. #define PA25_PF_CLS        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 25)
  276. #define PA26_PF_PS        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 26)
  277. #define PA27_PF_SPL_SPR        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 27)
  278. #define PA28_PF_HSYNC        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 28)
  279. #define PA29_PF_VSYNC        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 29)
  280. #define PA30_PF_CONTRAST    (GPIO_PORTA | GPIO_OUT | GPIO_PF | 30)
  281. #define PA31_PF_OE_ACD        (GPIO_PORTA | GPIO_OUT | GPIO_PF | 31)
  282. #define PB10_PF_CSI_D0        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 10)
  283. #define PB10_AF_UART6_TXD    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 10)
  284. #define PB11_PF_CSI_D1        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 11)
  285. #define PB11_AF_UART6_RXD    (GPIO_PORTB | GPIO_IN  | GPIO_AF | 11)
  286. #define PB12_PF_CSI_D2        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 12)
  287. #define PB12_AF_UART6_CTS    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 12)
  288. #define PB13_PF_CSI_D3        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 13)
  289. #define PB13_AF_UART6_RTS    (GPIO_PORTB | GPIO_IN  | GPIO_AF | 13)
  290. #define PB14_PF_CSI_D4        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 14)
  291. #define PB15_PF_CSI_MCLK    (GPIO_PORTB | GPIO_OUT | GPIO_PF | 15)
  292. #define PB16_PF_CSI_PIXCLK    (GPIO_PORTB | GPIO_OUT | GPIO_PF | 16)
  293. #define PB17_PF_CSI_D5        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 17)
  294. #define PB18_PF_CSI_D6        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 18)
  295. #define PB18_AF_UART5_TXD    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 18)
  296. #define PB19_PF_CSI_D7        (GPIO_PORTB | GPIO_OUT | GPIO_PF | 19)
  297. #define PB19_AF_UART5_RXD    (GPIO_PORTB | GPIO_IN  | GPIO_AF | 19)
  298. #define PB20_PF_CSI_VSYNC    (GPIO_PORTB | GPIO_OUT | GPIO_PF | 20)
  299. #define PB20_AF_UART5_CTS    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 20)
  300. #define PB21_PF_CSI_HSYNC    (GPIO_PORTB | GPIO_OUT | GPIO_PF | 21)
  301. #define PB21_AF_UART5_RTS    (GPIO_PORTB | GPIO_IN  | GPIO_AF | 21)
  302. #define PB22_PF_USBH1_SUSP    (GPIO_PORTB | GPIO_PF | 22)
  303. #define PB23_PF_USB_PWR        (GPIO_PORTB | GPIO_PF | 23)
  304. #define PB24_PF_USB_OC_B    (GPIO_PORTB | GPIO_PF | 24)
  305. #define PB25_PF_USBH1_RCV    (GPIO_PORTB | GPIO_PF | 25)
  306. #define PB26_PF_USBH1_FS    (GPIO_PORTB | GPIO_PF | 26)
  307. #define PB27_PF_USBH1_OE_B    (GPIO_PORTB | GPIO_PF | 27)
  308. #define PB28_PF_USBH1_TXDM    (GPIO_PORTB | GPIO_PF | 28)
  309. #define PB29_PF_USBH1_TXDP    (GPIO_PORTB | GPIO_PF | 29)
  310. #define PB30_PF_USBH1_RXDM    (GPIO_PORTB | GPIO_PF | 30)
  311. #define PB31_PF_USBH1_RXDP    (GPIO_PORTB | GPIO_PF | 31)
  312. #define PB26_AF_UART4_RTS    (GPIO_PORTB | GPIO_IN  | GPIO_PF | 26)
  313. #define PB28_AF_UART4_TXD    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 28)
  314. #define PB29_AF_UART4_CTS    (GPIO_PORTB | GPIO_OUT | GPIO_AF | 29)
  315. #define PB31_AF_UART4_RXD    (GPIO_PORTB | GPIO_IN  | GPIO_AF | 31)
  316. #define PC5_PF_I2C2_SDA        (GPIO_PORTC | GPIO_IN  | GPIO_PF | 5)
  317. #define PC6_PF_I2C2_SCL        (GPIO_PORTC | GPIO_IN  | GPIO_PF | 6)
  318. #define PC16_PF_SSI4_FS        (GPIO_PORTC | GPIO_IN  | GPIO_PF | 16)
  319. #define PC17_PF_SSI4_RXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 17)
  320. #define PC18_PF_SSI4_TXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 18)
  321. #define PC19_PF_SSI4_CLK    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 19)
  322. #define PC20_PF_SSI1_FS        (GPIO_PORTC | GPIO_IN  | GPIO_PF | 20)
  323. #define PC21_PF_SSI1_RXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 21)
  324. #define PC22_PF_SSI1_TXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 22)
  325. #define PC23_PF_SSI1_CLK    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 23)
  326. #define PC24_PF_SSI2_FS        (GPIO_PORTC | GPIO_IN  | GPIO_PF | 24)
  327. #define PC25_PF_SSI2_RXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 25)
  328. #define PC26_PF_SSI2_TXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 26)
  329. #define PC27_PF_SSI2_CLK    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 27)
  330. #define PC28_PF_SSI3_FS        (GPIO_PORTC | GPIO_IN  | GPIO_PF | 28)
  331. #define PC29_PF_SSI3_RXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 29)
  332. #define PC30_PF_SSI3_TXD    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 30)
  333. #define PC31_PF_SSI3_CLK    (GPIO_PORTC | GPIO_IN  | GPIO_PF | 31)
  334. #define PD0_AIN_FEC_TXD0    (GPIO_PORTD | GPIO_OUT | GPIO_AIN | 0)
  335. #define PD1_AIN_FEC_TXD1    (GPIO_PORTD | GPIO_OUT | GPIO_AIN | 1)
  336. #define PD2_AIN_FEC_TXD2    (GPIO_PORTD | GPIO_OUT | GPIO_AIN | 2)
  337. #define PD3_AIN_FEC_TXD3    (GPIO_PORTD | GPIO_OUT | GPIO_AIN | 3)
  338. #define PD4_AOUT_FEC_RX_ER    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 4)
  339. #define PD5_AOUT_FEC_RXD1    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 5)
  340. #define PD6_AOUT_FEC_RXD2    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 6)
  341. #define PD7_AOUT_FEC_RXD3    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 7)
  342. #define PD8_AF_FEC_MDIO        (GPIO_PORTD | GPIO_IN | GPIO_AF | 8)
  343. #define PD9_AIN_FEC_MDC        (GPIO_PORTD | GPIO_OUT | GPIO_AIN | 9)
  344. #define PD10_AOUT_FEC_CRS    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 10)
  345. #define PD11_AOUT_FEC_TX_CLK    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 11)
  346. #define PD12_AOUT_FEC_RXD0    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 12)
  347. #define PD13_AOUT_FEC_RX_DV    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 13)
  348. #define PD14_AOUT_FEC_CLR    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 14)
  349. #define PD15_AOUT_FEC_COL    (GPIO_PORTD | GPIO_IN | GPIO_AOUT | 15)
  350. #define PD16_AIN_FEC_TX_ER    (GPIO_PORTD | GPIO_OUT | GPIO_AIN | 16)
  351. #define PD17_PF_I2C_DATA    (GPIO_PORTD | GPIO_OUT | GPIO_PF | 17)
  352. #define PD18_PF_I2C_CLK        (GPIO_PORTD | GPIO_OUT | GPIO_PF | 18)
  353. #define PD19_AF_USBH2_DATA4    (GPIO_PORTD | GPIO_AF | 19)
  354. #define PD20_AF_USBH2_DATA3    (GPIO_PORTD | GPIO_AF | 20)
  355. #define PD21_AF_USBH2_DATA6    (GPIO_PORTD | GPIO_AF | 21)
  356. #define PD22_AF_USBH2_DATA0    (GPIO_PORTD | GPIO_AF | 22)
  357. #define PD23_AF_USBH2_DATA2    (GPIO_PORTD | GPIO_AF | 23)
  358. #define PD24_AF_USBH2_DATA1    (GPIO_PORTD | GPIO_AF | 24)
  359. #define PD25_PF_CSPI1_RDY    (GPIO_PORTD | GPIO_OUT | GPIO_PF  | 25)
  360. #define PD26_PF_CSPI1_SS2    (GPIO_PORTD | GPIO_OUT | GPIO_PF  | 26)
  361. #define PD26_AF_USBH2_DATA5     (GPIO_PORTD | GPIO_AF | 26)
  362. #define PD27_PF_CSPI1_SS1    (GPIO_PORTD | GPIO_OUT | GPIO_PF  | 27)
  363. #define PD28_PF_CSPI1_SS0    (GPIO_PORTD | GPIO_OUT | GPIO_PF  | 28)
  364. #define PD29_PF_CSPI1_SCLK    (GPIO_PORTD | GPIO_OUT | GPIO_PF  | 29)
  365. #define PD30_PF_CSPI1_MISO    (GPIO_PORTD | GPIO_IN | GPIO_PF  | 30)
  366. #define PD31_PF_CSPI1_MOSI    (GPIO_PORTD | GPIO_OUT | GPIO_PF  | 31)
  367. #define PF23_AIN_FEC_TX_EN    (GPIO_PORTF | GPIO_OUT | GPIO_AIN | 23)
  368. #define PE3_PF_UART2_CTS    (GPIO_PORTE | GPIO_OUT | GPIO_PF | 3)
  369. #define PE4_PF_UART2_RTS    (GPIO_PORTE | GPIO_IN  | GPIO_PF | 4)
  370. #define PE6_PF_UART2_TXD    (GPIO_PORTE | GPIO_OUT | GPIO_PF | 6)
  371. #define PE7_PF_UART2_RXD    (GPIO_PORTE | GPIO_IN  | GPIO_PF | 7)
  372. #define PE8_PF_UART3_TXD    (GPIO_PORTE | GPIO_OUT | GPIO_PF | 8)
  373. #define PE9_PF_UART3_RXD    (GPIO_PORTE | GPIO_IN  | GPIO_PF | 9)
  374. #define PE10_PF_UART3_CTS    (GPIO_PORTE | GPIO_OUT | GPIO_PF | 10)
  375. #define PE11_PF_UART3_RTS    (GPIO_PORTE | GPIO_IN  | GPIO_PF | 11)
  376. #define PE12_PF_UART1_TXD    (GPIO_PORTE | GPIO_OUT | GPIO_PF | 12)
  377. #define PE13_PF_UART1_RXD    (GPIO_PORTE | GPIO_IN  | GPIO_PF | 13)
  378. #define PE14_PF_UART1_CTS    (GPIO_PORTE | GPIO_OUT | GPIO_PF | 14)
  379. #define PE15_PF_UART1_RTS    (GPIO_PORTE | GPIO_IN  | GPIO_PF | 15)
  380. #define PE16_AF_RTCK        (GPIO_PORTE | GPIO_OUT | GPIO_AF | 16)
  381. #define PE16_PF_RTCK        (GPIO_PORTE | GPIO_OUT | GPIO_PF | 16)
  382. #define PE18_AF_CSPI3_MISO    (GPIO_PORTE | GPIO_IN  | GPIO_AF | 18)
  383. #define PE21_AF_CSPI3_SS    (GPIO_PORTE | GPIO_OUT | GPIO_AF | 21)
  384. #define PE22_AF_CSPI3_MOSI    (GPIO_PORTE | GPIO_OUT | GPIO_AF | 22)
  385. #define PE23_AF_CSPI3_SCLK    (GPIO_PORTE | GPIO_OUT | GPIO_AF | 23)
  386. #endif
  387.  
  388. /* decode irq number to use with IMR(x), ISR(x) and friends */
  389. #define IRQ_TO_REG(irq) ((irq - MXC_MAX_INT_LINES) >> 5)
  390.  
  391. #define IRQ_GPIOA(x)  (MXC_MAX_INT_LINES + x)
  392. #define IRQ_GPIOB(x)  (IRQ_GPIOA(32) + x)
  393. #define IRQ_GPIOC(x)  (IRQ_GPIOB(32) + x)
  394. #define IRQ_GPIOD(x)  (IRQ_GPIOC(32) + x)
  395.  
  396. #endif /* _MXC_GPIO_MX1_MX2_H */
  397.